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(57) Abstract: A computing entity comprises a trusted 
monitoring component having a first processing means and 
a first memory means, the trusted monitoring component 
being a self-contained autonomous data processing unit, 
and a computer platform having a main processing 
means and a main memory area, along with a plurality of 
associated physical and logical resources such as peripheral 
devices including printers, modems, ^plication programs, 
operating systems and the like. The computer platform 
is capable of entering a plurality of different states of 
operation, each state of operation having a different level 
of security and trustworthiness. Selected ones of the states 
comprise trusted states in which a user can enter sensitive 
confidential information with a high degree of certainty 
that the computer platform has not been compromised 
by external influences such as viruses, hackers or 
hostile attacks. To enter a trusted state, references made 
automatically to the trusted component, and to exit a trusted 
state reference must be made to the trusted component 
On exiting the trusted state, all references to the trusted 
state are deleted from the computer platform. On entering 
die trusted state, the state is entered in a reproducible 
and known manner, having a reproducible and known 
configuration which is confirmed by die trusted component 
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OPERATION OF TRUSTED STATE IN COMPUTING PLATFORM 

FMdQfthg Invention 

The present invention relates to the field of computers, and particularly, 
5 although not exclusively, to a computing entity which can be placed into a trusted 
state, and a method of operating the computing entity to achieve the tmsted 
state, and operation of the computing entity when in the tmsted state. 

PgcHgroupc^ to th9 hvpntjon 

10 Conventional prior art mass market computing platforms include the well- 

known personal computer (PC) and competing products such as the Apple 
Macintosh™, and a proliferation of known palm-top and laptop personal 
computers. Generally, markets for such machines fall into two categories, these 
being domestic or consumer, and corporate. A general requirement for a 

15 computing platform for domestic or consumer use is a relatively high processing 
power, Internet access features, and multi-media features for handling computer 
games. Forthistypeofcomputingplatfonn, the Microsoft Windows® '95 and '98 
operating system products and Intel processors dominate the market 

2 0 On the other hand, for business use, there are a plethora of available 

proprietary computer platform solutions available aimed at organizations ranging 
from small businesses to multi-national organizations. In many of these 
applications, a server platfomi provides centralized data storage, and application 
functionality for a plurality of client stations. For business use, other key criteria 
25 are reliability, networking features, and security features. For such platfonms, the 
Microsoft Windows NT 4.0™ operating system is common, as well as the Unix™ 
operating system. 

With the increase in commercial activity transacted over the Internet, known 

3 0 as "e-commerce", there has been much interest in the prior art in enabling data 

P482.spec 
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transactions between computing platfonns over the Internet. However, because 
of the potential for fraud and manipulation of electronic data, in such proposals, 
fully automated transactions with distant unknown parties on a wide-spread scale 
as required for a fully transparent and efficient market place have so far been 
5 held back. The fundamental issue is one of taist between interacting computer 
platfonns for the making of such transactions. 

There have been several prior art schemes which are aimed at increasing 
the security and trustworthiness of computer platfomis. Predominantly, these rely 

10 upon adding in security features at the application level, that is to say the security 
features are not inherently imbedded in the kernel of operating systems, and are 
not built in to the fundamental hardware components of the computing platform. 
Portable computer devices have already appeared on the market which include a 
smart card, which contains data specific to a user, which is input into a smart card 

15 reader on the computer. Presently, such smart cards are at the level of being 
add-on extras to conventional personal computers, and in some cases are 
integrated into a casing of a known computer. Although these prior art schemes 
go some way to improving the security of computer platfomris, the levels of 
security and trustworthiness gained by prior art schemes may be considered 

20 insufficient to enable widespread application of automated transactions between 
computer platforms. For businesses to expose significant value transactions to 
electronic commerce on a widespread scale, they require confidence in the 
tmstworthiness of the underiying technology. 

25 Prior art computing platfonns have several problems which stand in the way 

of increasing their inherent security: 

• The operating status of a computer system or platfomi and the status of the 
data within the platfomn or system is dynamic and difficult to predict. It is 
30 difficult to determine whether a computer platfomn is operating conrectly 



wo 01/27722 



PCT/GBdO/03613 



-3- 

because the state of the computer platform and data on the platform is 
constantly changing and the computer platfomn Itself may be dynamically 
changing. 

5 • From a security point of view, commercial computer platfonns, in particular 
client platfonns, are often deployed in environments which are vulnerable to 
unauthorized modification. The main areas of vulnerability include 
modification by software loaded by a user, or via a network connection. 
Particularly, but not exclusively, conventional computer platfonns may be 
10 vulnerable to attack by vims programs, with varying degrees of hostility. 

• Computer platforms may be upgraded or their capabilities may be extended 
or restricted by physical modification, i.e. addition or deletion of components 
such as hard disk drives, peripheral drivers and the like. 

15 

It is known to provide security features for computer systems, which are 
embedded in operating software. These security features are primarily aimed at 
providing division of infonnation within a community of users of the system. In 
the known Microsoft Windows NT™ 4.0 operating system, there exists a 

20 monitoring facility called a "system log event viewer" in which a log of events 
occuning within the platform is recorded Into an event log data file which can be 
inspected by a system administrator using the windows NT operating system 
software. This facility goes some way to enabling a system administrator to 
security monitor pre-selected events. The event logging fijnction in the Windows 

2 5 NT™ 4.0 operating system provides system monitoring. * 

In tenns of overall security of a computer platfonn, a purely software based 
system is vulnerable to aftack, for example by viruses of which there are 
thousands of different varieties. Several proprietary virus finding and con'ecting 
30 applications are known, for example the Dr Solomons ™ vims toolkit program 
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The Microsoft Windows NT™ 4.0 software includes a vims guard software, wliich 
is preset to look for known viruses. However, virus strains are developing 
continuously, and the virus guard software will not give reliable protection against 
newer unknown viruses. New strains of virus are being developed and released 
into the computing and internet environment on an ongoing basis. 

Further, prior art monitoring systems for computer entities ft)cus on network 
monitoring ftjnctions, where an administrator uses network management software 
to monitor perfomriance of a plurality of network computers. In these known 
systems, trust in the system does not reside at the level of individual trust of each 
hardware unit of each computer platfonm in a system. 

$Hmmary of thg tnvgntfpn 

One object of the present invention is to provide a computing entity in which 
a third party user can have a high degree of confidence that the computing entity 
has not been corrupted by an extemal influence, and is operating in a predictable 
and known manner. 

Another object of the present invention Is to simplify a task of judging 
whether a trustworthiness of a computing entity is sufficient to perform a 
particular task or set of tasks or type of task. 

In specific implementations of the present invention, a computing entity Is 
capable of residing in a plurality of distinct operating states. Each operating state 
can be distinguished from other operating states using a set of integrity metrics 
designed to distinguish between those operating states. 

According to first aspect of the present invention there is provided a 
computing entity comprising: 
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a computer platform comprising a plurality of physical and logical resources 
including a first data processor and a first memory means; 

a monitoring component comprising a second data processor and a second 
5 memory means; 

wherein, said computer platfomi is capable of operating in a plurality of 
different states, each said state utilising a corresponding respective set of 
individual ones of said physical and logical resources; 

10 

wherein said monitoring component operates to determine which of said 
plurality of states said computer platform operates in. 

Preferably a said memory means contains a set of instructions for 
15 configuration of said plurality of physical and logical resources of said computer 
platform into said pre-determined state. 

Preferably exit of said computer platform from said pre-determined state is 
monitored by said monitoring component. 

20 . 

A BIOS file may be provided within the monitoring component itself. By 
providing the BIOS file within the monitoring component, the BIOS file may be 
inherently tmsted. 

25 In an alternative embodiment, said computer platform may comprise an 

internal firmware component configured to compute a digest data of a BIOS file 
data stored in a predetermined memory space occupied by a BIOS file of said 
computer platfomi. 



wo 01/27722 



PCT/GBOO/03613 



-6- 

According to second aspect of the present invention there is provided a 
method of activating a computing entity comprising a computer platform having a 
first data processing means and a first memory means and a monitoring 
component having a second data processing means and a second memory 
5 means, into an operational state of a plurality of pre-configured operational states 
into which said computer platfomri can be activated, said method comprising the 
steps of: 

selecting a state of said plurality of pre-configured operational states into 
1 0 which to activate said computer platfomi; 

activating said computer platfomn into said selected state according to a set 
of stored instoictions; and 

15 wherein said monitoring component monitors activation into said selected 

state by recording data describing which of said plurality of pre-configured states 
said computer platform is activated into. 

Said monitoring component may continue to monitor said selected state 
20 after said computer platfonm has been activated to said selected state. 

Said monitoring component may generate a state signal in response to a 
signal input directly to said monitoring component by a user of said computing 
entity, said state signal containing data describing which said state said computer 
25 platform has entered. 

In one embodiment, said set of stored instmctions which allow selection of 
said state may be stored in a BIOS file resident within said monitoring 
component. Once selection of a said state has been made, activation of the state 
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may be carried out by a set of master boot instructions which are themselves 
activated by the BIOS. 

Preferably the method comprises the step of generating a menu for 
5 selection of a said pre-configured state from said plurality of pre-configured 
states. 

The method may comprise the step of generating a user menu displayed 
on a user interface for selection of a said pre-configured state from said plurality 
10 of pre-configured states, and said step of generating a state signal comprises 
generating a state signal in response to a user input accepted through said user 
interface. 

Altematively, the predetennined state may be automatically selected by a 
15 set of instructions stored on a smartcard, which selects a state option generated 
by said BIOS. The selection of states may be made automatically via a set of 
selection instructions to instruct said BIOS to select a state from said set of state 
options generated by said BIOS. 

2 0 Said step of monitoring a said state may comprise: 

immediately before activating said computer platfomri, creating by means 
of a finnware component a digest data of a first pre-allocated memory space 
occupied by a BIOS file of said computer platform; 

25 

writing said digest data to a second pre-allocated memory space to which 
only said finnware component has write access; and 

said monitoring component reading said digest data from said second pre- 

3 0 allocated memory space. 
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Said step of monitoring a said state into which said computer platfonn is 
activated may comprise: 

5 executing a fimnware component to compute a digest data of a BIOS file of 

said computer platform; 

writing said digest data to a predetemnined location In said second 
memory means of said monitoring component. 

10 

Said step of activating sard computer platform into said selected state may 
comprise: 

at a memory location of said first memory means, said location occupied 
15 by a BIOS file of said computer platform, storing an address of said monitoring 
component which transfers control of said first processor to said monitoring 
component; 

storing in said monitoring component a set of native instructions which are 
20 accessible immediately after reset of said first processor, wherein said native 
instmctions instmct said first processor to calculate a digest of said BIOS file and 
store said digest data in said second memory means of said monitoring 
component; and 

25 said monitoring component passing control of said activation process to 

said BIOS file, once said digest data is stored in said second memory means. 

Said step of monitoring said state into which said computer platform is 
activated may comprise: 

30 
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after said step of activating said computer platform into said selected state, 
monitoring a plurality of logical and physical components to obtain a first set of 
metric data signals from those components, said metric data signals describing a 
status and condition of said components; 

5 

comparing said first set of metric data signals detennined from said 
plurality of physical and logical components of said computer platfonn, with a set 
of pre-recorded metric data stored in a memory area reserved for access only by 
said monitoring component; and 

10 

comparing said first set of metric data signals obtained directly from said 
plurality of physical and logical components with said set of pre-stored metric 
data signals stored in said reserved memory area. 

15 According to a third aspect of the present invention there is provided a 

method of operating a computing entity comprising a computer platform having a 
first data processing means and a first memory means, and a monitoring 
component having a second data processing means and a second memory 
means, such that said computer platfonn enters one of a plurality of possible pre- 

20 detemnined operating states said method comprising the steps of: 

in response to an input from a user interface, generating a state signal, said 
state signal describing a selected state into which said computer platfonn is to be 
activated into; 

25 

activating said computer platfomi into a pre-determined state, in which a 
known set of physical and logical resources are available for use in said state and 
known processes can operate in said state; 
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from said pre-determined state, entering a configuration menu for 
reconfiguration of said monitoring component; and 

modifying a configuration of said monitoring component by entering data via 
5 a user interface in accordance with an instruction set comprising said 
configuration menu. 

Said step of entering said monitoring component configuration menu may 
comprise: 

10 

entering a confirmation l<ey signal directly into said monitoring component, 
said confimiation key signal generated in response to a physical activation of a 
confirmation key. 

15 Said step of entering said monitoring component configuration menu may 

comprise entering a password to said tmsted component via a user interface. 

According to a fourth aspect of the present invention there is provided a 
method of operation of a computing entity comprising a monitoring component 
20 having a first data processing means and a first memory means, and a computer 
platfomi having a second data processing means and a second memory means, 
said method comprising the steps of: 

entering a first state of said computer entity, wherein in said first state are 
25 available a plurality of pre-selected physical and logical resources; 

commencing a user session In said first state, in which said user session 
a plurality of data inputs are received by said computer platfonn, said second 
data processing means perfonning data processing on said received data; 



30 
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reconfiguring said plurality of physical and logical resources according to 
instructions received in said session; 

generating a session data describing a configuration of said physical and 
5 logical resources; 

generating a plurality of user data resulting from processes operating 
within said session; 

1 0 storing said user data; 

storing session data; 

exiting said session; and 

15 

exiting said computer platfonn from said state. 

Said method may further comprise the step of reconfiguring said 
20 monitoring component during said user session in said first state. Thus, the 
monitoring component may be reconfigured from a trusted state of the computer 
platform. 

Brief Descrip tion of the Drawings 

25 For a better understanding of the invention and to show how the same may 

be canied into effect, there will now be described by way of example only, 
specific embodiments, methods and processes according to the present 
invention with reference to the accompanying drawings in which: 
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Fig. 1 illustrates schematically a computer entity according to first specific 
embodiment of the present invention; 

Fig. 2 illustrates schematically connectivity of selected components of the 
5 computer entity of Fig . 1 ; 

Fig. 3 illustrates schematically a hardware architecture of components of the 
computer entity of Fig. 1 ; 

10 Fig. 4 illustrates schematically an architecture of a tmsted component 

comprising the computer entity of Fig. 1 ; 

Fig. 5 illustrates schematically a logical architecture of the computer entity, 
divided into a monitored user space resident on a computer platfomri and a 
15 trusted space resident on the trusted component; 

Fig. 6 illustrates schematically a set of physical and logical resources 
comprising the computer entity, wherein different combinations of usage and 
accessibility to the individual physical and logical resources con-esponds with 
2 0 operation in different states of the computing entity; 

Fig. 7 illustrates schematically an example of a state diagram illustrating a 
set of states into which the computing entity can be placed, and processes for 
entry and exit from those states; 

25 

Fig. 8 illustrates schematically a use model followed by a user of the 
computing entity for entry and exit from individual states of the computing entity; 



Fig. 9 illustrates schematically steps of a process for entry into a trusted 

30 state; 
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Fig. 10 illustrates schematically a first mode of operation of tfie computing 
entity in a trusted state, in which a first session is earned out by a user; 

5 Fig. 1 1 illustrates schematically a second session canied out in a trusted 

state, wherein the second session is canied out after closure of the first session; 
and 

Fig. 12 illustrates schematically a second mode of operation of the 
10 computer entity in which reconfiguration of a trusted component may be made by 
a user. 

Dgtaileci pgggriptlon gf th9 Best Mpdg for Cgirying Out the Iny^ntipn 
There will now be described by way of example the best mode 
15 contemplated by the Inventors for canrying out the invention. In the following 
description numerous specific details are set forth in order to provide a thorough 
understanding of the present invention. It will be apparent however, to one 
sl<illed in the art, that the present invention may be practiced without limitation to 
these specific details. In other instances, well known methods and structures 
2 0 have not been described in detail so as not to unnecessarily obscure the present 
invention. 

Specific embodiments of the present invention comprise a computer 
platform having a processing means and a memory means, and which is 
2 5 physically associated with a component, known herein after as a "trusted 
component" which monitors operation of the computer platform by collecting 
metrics data from the computer platfonm, and which is capable of verifying to third 
party computer entities interacting with the computer platform to the correct 
functioning of the computer platform. 

30 
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Two computing entities each provisioned with such a trusted component, 
may interact with each other with a high degree of *tmst'. That is to say, where 
the first and second computing entities interact with each other the security of the 
Interaction is enhanced compared to the case where no tmsted component is 
5 present because: 

• A user of a computing entity has higher confidence in the integrity and 
security of his/her own computer entity and in the Integrity and security of the 
computer entity belonging to the other computing entity. 

10 

• Each entity is confident that the other entity is in fact the entity which It 
purports to be. 

• Where one or both of the entities represent a party to a transaction, e.g. a 
15 data transfer transaction, because of the in-built tmsted component, third 

party entities interacting with the entity have a high degree of confidence that 
the entity does in fact represent such a party. 

• The trusted component increases the inherent security of the entity itself. 
20 through verification and monitoring processes implemented by the trusted 

component. 

• The computer entity is more likely to behave in the way it is expected to 
behave. 

25 

In this specification, the term 'tmsted" when used in relation to a physical or 
logical component, is used to mean a physical or logical component which always 
behaves in an expected manner. The behavior of that component is predictable 
and known. Tmsted components have a high degree of resistance to 
3 0 unauthorized modification. 
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In this specification, the term "computer platform" Is used to refer to at least 
one data processor and at least one data storage means, usually but not 
essentially with associated communications facilities e.g. a plurality of drivers, 
5 associated applications and data files, and which may be capable of interacting 
with external entities e.g. a user or another computer entity, for example by 
means of connection to the internet, connection to an external network, or by 
having an input port capable of receiving data stored on a data storage medium, 
e.g. a CD ROM, floppy disk, ribbon tape or the like. The temi "computer 
10 platform" encompasses the main data processing and storage facility of a 
computer entity. 

Referring to Fig. 1 herein, there is illustrated schematically one example of a 
computer entity according to a specific implementation of the present invention. 
15 Refening to Fig. 2 of the accompanying drawings, there is illustrated 
schematically physical connectivity of some of the components of the tnjsted 
computer entity of Fig, 1. Referring to Fig. 3 herein, there is illustrated 
schematically an architecture of the trusted computer entity of Figs. 1 and 2, 
showing physical connectivity of components of the entity. 

20 

In general, in the best mode described herein, a tnjsted computer entity 
comprises a computer platform consisting of a first data processor, and a first 
memory means, together with a trusted component which verifies the integrity 
and correct functioning of the computing platform. The trusted component 
25 comprises a second data processor and a second memory means, which are 
physically and logically distinct from the first data processor and first memory 
means. 

In the example shown in Figs. 1 to 3 herein, the tmsted computer entity is 
3 0 shown in the form of a personal computer suitable for domestic use or business 
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use. However, it will be understood by those skilled in the art that that this is just 
one specific embodiment of the invention, and other embodiments of the 
invention may take the fbmn of a palmtop computer, a laptop computer, a server- 
type computer, a mobile phone-type computer, or the like and the Invention is 
limited only by the scope of the claims herein. In the best mode example 
described herein, the computer entity comprises a display monitor 100; a 
keyboard data entry means 101; a casing 102 comprising a motheriixjard on 
which is mounted a data processor; one or more data storage means e.g. hard 
disk drives; a dynamic random access memory; various Input and output ports 
(not illustrated in Fig. 1); a smart card reader 103 for accepting a user's smart 
card; a confirmation key 104, which a user can activate when confinning a 
transaction via the trusted computer entity; and a pointing device, e.g. a mouse or 
trackball device 105; and a trusted component. 

Refening to Fig. 2 herein, there are Illustrated some of the components 
comprising the tnjsted computer entity. Including keyboard 101, which 
incorporates confimnation key 104 and smart card reader 103; a main 
motherboard 200 on which is mounted first data processor 201 and trusted 
component 202, an example of a hard disc drive 203, and monitor 100. 
Additional components of the trusted computer entity, include an internal frame to 
the casing 102, housing one or more local area networi^ (LAN) ports, one or more 
modem ports, one or more power supplies, cooling fans and the like (not shown 
in Fig. 2). 

In the best mode herein, as illustrated in Fig. 3 herein, main motherboard 
200 is manufactured comprising a first data processor 201; and preferably a 
pennanently fixed trusted component 202; a local memory device 300 to the first 
data processor, the local memory device being a fast access memory area, e.g. a 
random access memory; a BIOS memory area 301; smart card interface 305; a 
plurality of control lines 302; a plurality of address lines 303; a confimiation key 
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interface 306; and a data bus 304 connecting the processor 201, trusted 
component 202, memory area 300, a BIOS memory component 301 and smart 
card internee 305. A hardware random number generator RNG 309 is also able 
to communicate with the processor 201 using the bus 304. 

External to the motherboard and connected thereto by data bus 304 are 
provided the one or more hard disk drive memory devices 203, l<eyboard data 
entry device 101, pointing device 105, e.g. a mouse, trackball device or the like; 
monitor device 100; smart card reader device 103 for accepting a smart card 
device as described previously; the disk drive(s), keyboard, monitor, and pointing 
device being able to communicate with processor 201 via said data bus 304; and 
one or more peripheral devices 307, 308. for example a modem, printer scanner 
or other known peripheral device. 

To provide enhanced security confinmation key switch 104 is hard wired 
directly to confirmation key interface 306 on motheriDoard 200, which provides a 
direct signal input to trusted component 202 when confirmation key 104 is 
activated by a user such that a user activating the confirmation key sends a 
signal directly to the trusted component, by-passing the first data processor and 
first memory means of the computer platfomn. 

In one embodiment the confirmation key may comprise a simple switch. 
Confirmation key 104, and confirmation key driver 306 provide a protected 
communication path (PCP) between a user and the trusted component, which 
cannot be interfered with by processor 201. which by-passes data bus 304 and 
which is physically and logically unconnected to memory area 300 or hard disk 
drive memory device(s) 203. 

Trusted component 202 is positioned logically and physically between 
monitor 100 and processor 201 of the computing platform, so that the trusted 
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component 202 has direct crantrol over the views displayed on monitor 100 which 
cannot be interfered with by processor 20 1 . 

The trusted component lends its identity and trusted processes to the 
computer platfomi and the trusted component has those properties by virtue of its 
tamper-resistance, resistance to forgery, and resistance to counterfeiting. Only 
selected entities with appropriate authentication mechanisms are able to 
influence the processes mnning inside the trusted component. Neither a user of 
the tmsted computer entity, nor anyone or any entity connected via a networic to 
the computer entity may access or interfere with the processes running inside the 
tnjsted component. The trusted component has the property of being "inviolate". 

Smart card reader 103 is wired directly to smart card interface 305 on the 
motherboard and does not connect directly to data bus 304. Alternatively, smart 
canJ reader 103 may be connected directly to data bus 304. On each individual 
smart card may be stored a con^sponding respective image data which is 
different for each smart card. For user interactions with the trusted component, 
e.g. for a dialogue box monitor display generated by the trusted component, the 
trusted component tal<es the image data from the user's smart card, and uses 
this as a background to the dialogue box displayed on the monitor 100. Thus, 
the user has confidence that the dialogue box displayed on the monitor 100 is 
generated by the tmsted component. The image data is preferably easily 
recognizable by a human being in a manner such that any forgeries would be 
immediately apparent visually to a user. For example, the image data may 
comprise a photograph of a user. The image data on the smart card may be 
unique to a person using the smart cand. 

Refening to Fig. 4 herein, there is illustrated schematically an internal 
architecture of taisted component 202. The tmsted component comprises a 
processor 400, a volatile memory area 401 ; a non-volatile memory area 402; a 
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memory area storing native code 403; and a memory area storing one or a 
plurality of cryptographic functions, 404, the non-volatile memory 402, native 
code memory 403 and cryptographic memory 404 collectively comprising the 
second memory means herein before refenred to. 

5 

Trusted component 202 comprises a physically and logically independent 
computing entity from the computer platfomn. In the best mode herein, the 
trusted component shares a motherboard with the computer platform so that the 
trusted component is physically linked to the computer platform. In the best 

10 mode, the trusted component is physically distinct from the computer platfomri, 
that is to say it does not exist solely as a sub-functionality of the data processor 
and memory means comprising the computer platfomn, but exists separately as a 
separate physical data processor 400 and separate physical memory area 401, 
402, 403, 404. By providing a physically present trusted component separate 

15 from a main processor of the computer entity, the trusted component becomes 
harder to mimic or forge through software introduced onto the computer platform. 
Another benefit which arises from the trusted component being physical, 
separate from the main processor of the platform, and tamper resistant is that the 
tmsted component cannot be physically subverted by a local user, and cannot be 

20 logically subverted by either a local user or a remote entity. Programs within the 
trusted component are pre-loaded at manufacture of the tmsted component in a 
secure environment. The programs cannot be changed by users, but may be 
configured by users, if the programs are written to penmit such configuration. The 
physicality of the tmsted component, and the fact that the tmsted component is 

25 not configurable by the user enables the user to have confidence in the inherent 
integrity of the tmsted component, and therefore a high degree of "tmst" in the 
operation and presence of the tmsted component on the computer platfomn. 

Refening to Fig. 5 herein, there is illustrated schematically a logical 
3 0 architecture of the computer entity 500. The logical architecture has a same basic 
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division between the computer platform, and the trusted cx)mponent, as is present 
with the physical architecture described in Figs. 1 to 3 herein. That is to say, the 
trusted component is logically distinct from the computer platfomn to which it is 
physically related. The computer entity comprises a user space 501 being a 
logical space which is physically resident on the computer platfomn (the first 
processor and first data storage means) and a trusted component space 502 
being a logical space which is physically resident on the trusted component 202. 
In the user space 501 are one or a plurality of drivers 503, one or a plurality of 
applications programs 504, a file storage area 505; smart card reader 103; smart 
card interface 305; and a software agent 506 which operates to perfomi 
operations in the user space and report back to tmsted component 202. The 
tmsted component space is a logical area based upon and physically resident in 
the trusted component, supported by the second data processor and second 
memory area of the taisted component. Confimiation key device 104 Inputs 
directly to the trusted component space 502, and monitor 100 receives images 
directly from the trusted component space 502. Extemal to the computer entity 
are extemal communications networks e.g. the Intemet 507, and various local 
area networi^s, wide area networks 508 which are connected to the user space 
via the drivers 503 which may include one or more modem ports. Extemal user 
smart card 509 inputs into smart card reader 103 in the user space. 

In the tmsted component space, are resident the trusted component itself, 
displays generated by the trusted component on monitor 100; and confimiation 
key 104. inputting a confirmation signal via confimiation key interface 306. 

In the best mode for canrying out the invention, the computing entity has a 
plurality of modes of operation, referred to herein as operating states. Different 
ones of the plurality of operating states allow the computing entity to perform 
different sets of tasks and functionality. In some of the individual states, complex 
operations can be earned out with a large number of degrees of freedom, and 



wo 01/27722 



PCT/GBOO/03613 



-21. 

complexity. In other operating states, there are more restrictions on the behavior 
of the computing entity. 

The level of trust' which can be placed on the computing entity when 
operating in each of the plurality of different states is related to: 

• The number of different operations which can be carried out in a 
particular state 

• The complexity of operations which can be carried out in a particular 

state. 

• A number of other states Into which the computing entity can move 
from the particular state, without re-booting the computing entity. 

• A number of different states from which the particular state can be 
anived at, without re-booting the computing entity. 

• The connectivity of the computing entity when in the particular state, 
that is to say, how many other computing entities or devices the entity is 
connectable to. e.g. over the internet, a wide area networi^, or a local area 
network. 

• Restrictions on input of data from an external source, e.g. another 
computing entity, a floppy disl<. a CD ROM, a modem, a LAN port, or the like. 

• Restrictions on output of data from the particular state to other 
computing entities, e.g. whether data can be saved to a CD writer, floppy disc 
drive, or exported through an interface to a further computer entity over the 
intemet, a local area network, or a wide area network. 

• An amount of, and a reliability of, intemal monitoring processes within 
the computer entity which occur in the particular state; that is to say, the amount 
and reliability of a set of metrics applied by the trusted component when in that 
state. 

• A number of checks which need to be made before a user can enter 
the particular state. 
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• A difficulty of bypassing one or a plurality of checks which need to be 
made before a user can enter the particular state. 

• A difficulty of overcoming, without bypassing, one or a plurality of 
checks which are made before a user of the computer entity can enter the 
computing entity into the particular state. 

The trust placed in the computer entity is composed of two separate parts; 

• The tnjst placed in the trusted component itself. 

• The certainty with which the tmsted component can verify operation of 
the computer entity. 

As described herein, levels or degrees of trust placed in the computer entity 
are detemiined as being relative to a level of trust which is placed in the tmsted 
component. Although the amount of trust in a computer entity is related to many 
factors, a key factor in measuring that trust are the types, extent and regularity of 
integrity metric checks which the trusted component itself cam'es out on the 
computer entity. 

The trusted component is impliedly tnjsted. The trusted component Is 
embedded as the root of any trust which is placed in the computing platform and 
the computing platfonn as a whole cannot be any more tmsted than the amount 
of tmst placed in the tmsted component. 

By virtue of the tmsted component monitoring operations of the computer 
platfomi, the tmst placed in the tmsted component can be extended to various 
parts of the computer platfonn, with the level and extent of tmst placed in 
individual areas of the computer platfomi, being dependent upon the level and 
reliability with which the tmsted component can monitor that particular area of the 
computing platfonn. 
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Since the taisted areas of the computing platform are dependent upon the 
frequency, extent, and thoroughness with which the trusted component applies a 
set of integrity metric measurements to the computer platfonm, if the trusted 
component does not comprehensively measure all measurable aspects of the 
operation of the computing platfomri at all times, then the level of trust placed in 
individual parts of the computer platform will form a subset of the overall trust 
placed in the tmsted component itself. If the computing entity supports only a 
limited number of integrity metrics, a user of the equipment, Including a third party 
computing entity, is restricted in Its ability to reason about the level of trust which 
can be placed in the computing entity. 

Although various islands of the computer platform are trusted at various 
levels, depending upon the integrity metrics which are applied by the trusted 
component for measuring those areas of the computer platfomi, the level of trust 
placed in the computer platfomn as a whole is not as high as that which is 
inherent in the trusted component. That is to say, whilst the trusted component 
space 502 is tmsted at a highest level, the user space 501 may comprise several 
regions of various levels of trust. For example, applications programs 504 may 
be relatively untrusted. Where a user wishes to use the computer entity for an 
operation which involves a particulariy high degree of confidentiality or secrecy, 
for example worthing on a new business proposal, setting pay scales for 
employees or equally sensitive operations, then the human user may become 
worried about entering such details onto the computer platform because of the 
risk that the confidentiality or secrecy of the information will become 
compromised. The confidential infonnatlon must be stored in the computing 
entity, and islands of high tmst may not extend over the whole computing 
platform uniformly and with the same degree of trust. For example, it may be 
easier for an intruder to access particular areas or files on the computing platform 
compared with other areas or files. 
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Additionally, a user may wish to Instruct the trusted component to perform 
certain functions, this poses the problem that all the commands to instnjct the 
trusted component must pass through the computer platform, which is at a lower 
level of trust than the trusted component itself. Therefore, there is a risk of the 
commands to the tmsted component becoming compromised during their 
passage and processing through the computer platform. 

According to specific implementations of the present invention, the 
computer entity may enter a plurality of different states, each state having a 
corresponding respective level of trust, wherein the individual levels of tmst 
conresponding to different states may be different from each other. 

Refening to Fig. 6, there is illustrated schematically a set of physical and 
logical resources available to the computing entity. In the general case, the 
computing entity comprises a plurality of input/output devices 600 for 
communicating with other computing entities, examples of such devices including 
a modem, a local area networi^ port, an Ethernet card, a hard disk drive 203, a 
floppy disk drive, and a smart card reader device 103; a plurality of memory areas 
601-603, resident on the hard disk 203, or ram 300; one or a plurality of operating 
systems 604-606; and one or a plurality of application programs 607-609. 

In this specification, by the term "state" when used in relation to a computing 
entity, it is meant a mode of operation of the computing entity in which a plurality 
of functions provided by the computing platfonn may be earned out. For example 
in a first state, the computing entity may operate under control of a first operating 
system, and have access to a first set of application programs, a first set of files, 
and a first set of communications capabilities, for example modems, disk drives, 
local area networi< cards, e.g. Ethernet cards. In a second state, the computing 
platfonn may have access to a second operating system, a second set of 
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applications, a second set of data files and a second set of input/output 
resources. Similarly, for successive third, fourth states up to a total number of 
states into which the computing entity can be set. There can be overlap between 
the facilities available between two different states. For example, a first and 
second state may use a same operating system, whereas a thtnj state may use a 
different operating system. 

Refening to Fig. 7 herein, there is illustrated schematically a state diagram 
representing a plurality of states into which the computing entity may be placed. 
In principle, there is no limit to the number of different states which the computing 
entity may be placed, but In the example shown in Fig. 7 three such states are 
shown. In the example of Fig. 7, the computing entity may be placed into a first, 
tmsted state 700, a second state 701 being a general purpose untrusted state 
and a third stale 702 being a general purpose untrusted state. In the general 
case, the computing entity can reside in a plurality of different states, each having 
a corresponding respective level of trust. 

Trusted state 700 is distinguished from the second and third states 701, 702 
by virtue of the way in which the trusted state can be accessed. In one option, 
tmsted state 700 can only be accessed by reference to the trusted component 
202. However, in the preferred best mode implementation entry into the tmsted 
state need not be controlled by the tmsted component. To access the tmsted 
state, a user may tum on the computing entity, that is to say turn on the power 
supply to the computing entity in a tum on process 703. Upon tuming on the 
power supply, the computing entity boots up via the BIOS file 301 in process 704, 
from a routine contained in the computer BIOS, The computing entity may enter 
either the tmsted state 700, the second state 701, or the third state 702. 
depending upon how the BIOS file is configured. In the best mode herein, a user 
of the computer entity has the option, provided as a menu display option on 
monitor 100 during boot up of the computer entity, or as a selectable option 
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presented as a screen icon, when in any state, to enter either the trusted state 
700, or one of the other states 701 , 702 by selection. For exannple on turn on , 
the BIOS may be configured to default boot up In to the second state 701 . Once 
in the second state, entry Into a different state 700 may require a key input from a 
user, which may involve entry of a password, or confirmation of the users identity 
by the user entering their smart card into smart card reader 103. 

Once the computing entity has entered a state other than the trusted state, 
e.g. the second state 701 or third state 702, then from those states the user may 
be able to navigate to a different state. For example the user may be able to 
navigate from the second state 701 to the third state 702 by normal key stroke 
entry operations on the keyboard, by viewing the monitor and using a pointing 
device signal input, usually with reference back to the BIOS. This is shown 
schematically as select new state process 705, 

In order to enter the trusted state 700, the computer entity must be either 
booted up for the first time after turn on process 704, or re-booted via the BIOS in 
re-boot process 706. Re-boot process 706 Is very similar to boot up process 704 
except that It can be entered without having to tum the power of the computing 
entity off and then on again. To leave the trusted state 700, the computing entity 
must again refer to the BIOS 704 which involves automatic monitoring by the 
trusted component 202 in monitor process 706. Similariy. re-booting via the 
BIOS in process 705 involves automatic monitoring by the tmsted component in 
monitoring process 706. 

To leave the trusted state 700, the tmsted state can only be left either by 
turning the power off in power down process 707, or by re-booting the computing 
entity in re-boot process 705. Re-booting the BIOS in re-boot process 705 
involves automatic monitoring by the trusted component 706. Once the trusted 
state is left, it is not possible to re-enter the tmsted state without either re-booting 



wo 01/27722 



PCT/GBOO/03613 



-27- 

the computing entity, in re-boot process 705, or booting up tiie computing entity 
after a power down In process 704, botln of whlchi involve automatic monitoring by 
tlie taisted component in monitoring process 706. 

5 Refemng to Fig. 8 herein, there is illustrated schematically a use model 

followed by a user of the computer entity navigating through one or more states. 
In step 800, after tuming on a power supply to the computing entity, the computer 
boots up via the BIOS program. The boot process is very similar to re-booting 
the computer from an existing state. In each case, control of microprocessor 201 

10 is seized by the BIOS component 301 . The trusted component 202 measures a 
set of integrity metric signals from the BIOS 301, to detemiine a status of the 
BIOS 301. In step 801, the graphical user interface displays a menu option for 
entry into a plurality of different states. One of the states displayed on the menu 
is a trusted state as described herein before. The user manually selects a state 

15 in which to enter by using the keyboard or pointing device of the graphical user 
interface, for example by cliclcing a pointer icon over a state icon displayed on the 
graphical user interface. Alternatively, an automatic selection of a state may be 
made by a smartcard or via a network connection from state selection options 
generated by the BIOS. After selection of a state, the BIOS loads a program 

2 0 which loads a selected operating system corresponding with the state. A different 

load program is used for each of the plurality of different possible states. The 
trusted component measures that program in broadly a similar way to the way in 
which it measures the BIOS, so that the trusted component can record and 
detemiine which state has been loaded. When an external entity requests that 
25 the trusted component supplies integrity metrics, the tmsted component supplies 
both the BIOS metrics and the loaded program metrics. In step 802, the 
computing entity enters the selected state. Once in the selected state, the user 
has access to a set of physical and logical resources in that state. For example, 
in a relatively insecure state, the user may have full internet access through a 

3 0 modem device comprising the computing entity, may have full access to one or a 
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plurality of hard disk drives or CD readers/writers, and may have full acx;ess to a 
floppy disk drive, as well as having acx:ess to a plurality of pre-loaded 
commercially available applications programs. On the other hand, if the user 
selects a trusted state having a relatively high level of trust, in that state the user 
5 may have available a single operating system, a limited set of applications, for 
example a word processor, accounts package, or database, and use of a printer 
device, but in that state, use of a hard disk drive, a floppy disk drive, or the 
intemet may be restricted. Each selection of a separate state into which the 
computer may be booted may be pre-configured by configuration of the BIOS 

10 component 301. A choice of states is presented by the BIOS to a user. Once a 
state is selected, the BIOS causes the selected state to load by calling up an 
operating system loading program to load that state. The states themselves are 
pre-configured by the loading and the relevant operating system. For entry into 
trusted states, entry into those states is via operation of the BIOS component 

15 301, and including monitoring by the trusted component in monitoring process 
706. In order to enter a trusted state, a user must boot or re-boot the computer 
platfomn in step 804. Similariy, to exit from a trusted state, the user must also 
boot or re-boot the computing entity in step 804. To navigate from a state having 
a lower trust level, for example the second state (701 ), or the third state (702), the 

20 user may navigate from that state to another state in step 805, which, in the best 
mode involves re-booting of the computing entity via the BIOS. 

Referring to Fig. 9 herein there is illustrated schematically process steps 
canied out by the computing entity for entering a state via boot process 704 or re- 
25 boot process 705. 

In step 900. the computer enters a boot up routine, either as a result of a 
power supply to the computing entity being turned on, or as a result of a user 
inputting a reset instruction signal, for example by clicking a pointer icon over a 
3 0 reset icon displayed on the graphical user interface, giving rise to a reset signal. 
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The reset signal is received by the trusted component, which monitors internal 
bus 304. The BIOS component 301 initiates a boot-up process of the computer 
platfomi in step 901. Trusted component 202 proceeds to make a plurality of 
integrity checl<s on the computer platfonn and in particular checks the BIOS 
5 component 301 in order to check the status of the computer platfonm. Integrity 
checks are made by reading a digest of the BIOS component The trusted 
component 202 acts to monitor the status of the BIOS, and can report to third 
party entities on the status of the BIOS, thereby enabling third party entities to 
determine a level of trust which they may allocate to the computing entity. 

10 

There are several ways to implement integrity metric measurement of the 
BIOS. In each case, the trusted component is able to obtain a digest of a BIOS 
file very early on in the boot up process of the computer platform. The following 
are examples: 

15 

• The BIOS component may be provided as part of the trusted component 202, 
in which the architecture illustrated in Fig. 3 herein is modified such that BIOS 
301 resides within tmsted component 202. 

• The first processor 201 of the computer platform may execute Immediately 
20 after reset, an Internal finmware component which computes a digest over a 

preset memory space occupied by a BIOS file. The first processor writes the 
digest to a preset memory space to which only the fimnware component is 
able to write to that memory space. The first processor reads from the BIOS 
file in order to boot the computer platfomn. At any time afterwards, the tmsted 
25 component reads data from a preset location within the memory space to 
obtain a BIOS digest data. 

• The trusted component may be addressed at a memory location occupied by 
BIOS 301, so that the tmsted component contains a set of first native 
instmctions which are accessed after reset of the first processor 201. These 

30 instmctions cause the first processor 201 of the computer platform to 
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calculate a digest of the BIOS, and store It in the trusted component. The 
trusted component then passes control to the BIOS 301 once the digest of the 
BIOS is stored in the tmsted component. 

• The trusted component may monitor a memory control line and a reset line 
and verify that the BIOS component 301 is the first memory location accessed 
after the computer platform resets. At some stage in the boot process, the 
BIOS passes control to the tnjsted component and the trusted component 
causes the first processor of the computer platfomi to compute a digest of the 
BIOS and retum the digest to the trusted component The process of 
computing the digest and writing the result to the toisted component must be 
atomic. This action may be started by the trusted component, causing the 
computer platfomn's processor to read a set of native instructions from the 
trusted component which causes the processor to compute a digest over a 
memory space occupied by the BIOS, and to write the digest data to the 
memory space occupied by the trusted component Alternatively, this action 
could be started by the trusted component causing the first processor of a 
platfomi to execute an instruction, where the processor computes a digest 
over a preset memory space occupied by the BIOS and writes the digest to a 
preset memory space occupied by the trusted component. 

• A loading program for loading a selected operating system is itself loaded by 
the BIOS program. Integrity metrics of the operating system loading program 
are also measured by computing a digest of the loading program. 

In one embodiment, trusted component 202 may interrogate individual 
components of the computer platfonn, in particular hard disk drive 203. 
microprocessor 201, and RAM 301, to obtain data signals directly from those 
individual components which describe the status and condition of those 
components. Tmsted component 202 may compare the metric signals received 
from the plurality of components of the computer entity with the pre-recorded 
metric data stored in a memory area reserved for access by the trusted 
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components. Provided that the signals received from the components of the 
computer platfomri coincide with and match those of the metric data stored within 
the memory, then the trusted component 202 provides an output signal 
confirming that the computer platfonn is operating correctly. Third parties, for 
example, other computing entities communicating with the computing entity may 
take the output signal as confimriation that the computing entity is operating 
con-eclly, that is to say is trusted. 

In step 903 BIOS generates a menu display on monitor 100 offering a user 
a choice of state options, including a tmsted state 700. The user enters details of 
which state is to be entered by making key entry to the graphical user interface or 
data entry using a pointing device, e.g. mouse 105. The BIOS receives key 
inputs from a user which instruct a state in to which to boot in step 904. The 
tmsted component may also require a separate input from confirmation key 104 
requiring physical activation by a human user, which bypasses internal bus 304 
of the computer entity and accesses trusted component 202 directly, in addition 
to the user key inputs selecting the state. Once the BIOS 301 has received the 
necessary key inputs instructing which state is required, the processing of the set 
of configuration instmctions stored in BIOS 301 occurs by microprocessor 201, 
and instnjcts which one of a set of state options stored in the BIOS file, the 
computer platfomn will Configure itself into. Each of a plurality of state selections 
into which the computer platform may boot may be stored as separate boot 
options within BIOS 301, with selection of the boot option being controlled in 
response to keystroke inputs or other graphical user inputs made by a user of the 
computing entity. Once the con-ect routine of BIOS file 301 is selected by the 
user, then in step 906, the BIOS file then releases control to an operating system 
load program stored irt a memory area of the computer platfonn, which activates 
boot up of the computer platform into an operating system of the selected state. 
The operating system load program contains a plurality of start up routines for 
initiating a state, which include routines for starting up a particular operating 



wo 01/27722 PCT/GBOO/03613 

-32- 

system corresponding to a selected state. The operating load program boots up 
the computer platfomi into the selected state. The operating system measures 
the metrics of the load program which is used to install the operating system, in 
step 907. Once in the selected state, trusted component 202 continues, in step 
5 908, to perfomri on an ongoing continuous basis further integrity check 
measurements to monitor the selected state continuously, looking for 
discrepancies, faults, and variations from the nomial expected operation of the 
computer platfonn within that state. Such integrity measurements are made by 
tmsted component 202 sending out interrogation signals to individual 

10 components of the computer platform, and receiving response signals from the 
individual components of the computer platfomi, which response signals the 
trusted component may compare with a predetermined preloaded set of expected 
response signals conresponding to those particular states which are stored within 
the memory of the trusted component, or the trusted component 202 compares 

15 the integrity metrics measured from the computer platfonn in the selected state 
with the set of integrity metrics initially measured as soon as the computer 
platfomi enters the selected state, so that on an ongoing basis any changes to 
the integrity metrics from those initially recorded can be detected. 

20 During the boot up procedure, although the tnjsted component monitors the 

boot up process carried out by the BIOS component, it does not necessarily 
control the boot up process. The tnjsted component acquires a value of the 
digest of the BIOS component 301 at an eariy stage in the boot up procedure. In 
some of the altemative embodiments, this may involve the tmsted component 

25 seizing control of the computer platfomi before boot up by the BIOS component 
commences. However, in altemative variations of the best mode implementation 
described herein, it is not necessary for the tmsted component to obtain control 
of the boot up process, but the tmsted component does monitor a computer 
platfonn, and in particular the BIOS component 301. By monitoring the computer 

3 0 platform, the tmsted component stores data which describes which BIOS options 
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have been used to boot up the computer, and which operating system has been 
selected. The trusted component also monitors the loading program used to 
install the operating system. 

5 There will now be described an example of operation of a computer entity 

wthin a trusted state in a first specific mode of operation according to the present 
invention. 

Refening to Figs. 10 and 11 herein, there Is illustrated schematically usage 
10 of the computing entity In a trusted state, extending over a plurality of user 
sessions, for example usage of the computing entity over two successive days, 
whilst turning off or re-booting the computing entity between sessions. 

Refening to Fig. 10 herein, a user boots up the computing entity Into a 

15 trusted state 700 as herein before described in a first boot process 1000. In the 
trusted state, the user commences a first session 1 001 of usage of the computing 
entity. Within the session, because the computer platfomi is booted into the 
trusted state, a predetemnlned set of logical and physical resources are available 
to the user within that trusted state. Typically, this would include access to an 

20 operating system and a predetenmined selection of applications. The level of 
tnjst which applies to the tmsted state varies depending upon the number, 
complexity and reliability or the physical and logical resources available to the 
user within the trusted state. For example, where the tmsted state is configured 
to use a well-known reliable operating system, for example UNIX, and a reliable 

25 word processing package with minimal access to peripheral devices of the 
computer platfomi being pennitted in the tmsted state, for example no access to 
modems, and access to output data restricted to a single writer drive, e.g. a CD 
writer, then this may have a relatively high degree of tmst. In another tmsted 
state, where more facilities are available, the tmst level would be different to that 

3 0 in a tmsted state in which more limited access to physical or logical resources. 
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However, each trusted state is characterized in that the access to facilities is 
predetermined and known and can be verified by trusted component 202. During 
the first session 1001, a user may call up an application 1002 available in the 
trusted state, and may enter user data 1003, for example via a keyboard device. 
5 The user data 1003 is processed according to the application 1002 in processing 
operation 1004, resulting in processed output user data 1005. During the course 
of the session, by virtue of using the computer platfonm, operating system and 
applications, the user may have reconfigured the applications and/or operating 
system for a specific usage within the session. For example, in a word processor 

10 application, documents may have been fomnatted with certain line spacing, font 
styles etc. To avoid these settings being lost on leaving the trusted state, such 
settings comprising session data 1006 may be stored during the session. 
Similariy, to avoid the effort made by the user during the session being lost, the 
output user data may be stored during the session. However, the user session 

15 1001 only exists in the trusted state as long as the trusted state exists. 
Therefore, to avoid loss of settings and data from the first session 1001 in the 
trusted state 700, the output user data and session data must be stored as stored 
output user data 1007 and stored session data 1008 respectively before the 
trusted state can be exited. The stored output user data 1007 and stored session 

20 data 1008 may be saved to a device available in the trusted state, for example 
hard disk drive 203 or a CD reader/writer peripheral for use in a further 
successive session, or be encrypted and signed and then saved at a remote 
location, accessed over a networi^. Preferably, signing of user data and session 
data is done by the trusted component and/or the user's smartcard. Exit from the 

25 trusted states involves closing the first user session 1001, and rebooting the 
computing entity via re-boot process 705, or powering down the computing entity 
via power down process 707. In the first user session in the tmsted state, 
processing of user input data occurs, and the output of the process is the output 
processed data. The output processed data is stored after processing of the data 
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has terminated, and before the session is ended, and before the trusted state is 
exited. 

Refening to Fig. 1 1 herein, there is Illustrated schematicaiiy operation of the 
computing entity on a second day, In a second session in the same trusted state 
700. Between the first and second sessions the tmsted state 700 disappears 
completely, since the computing entity leaves the trusted state 700. On leaving 
the trusted state 700, apart from the stored output user data and stored session 
data, the computer platfonn saves no infonnation concerning the tmsted state 
other than that which is pre-programmed into the BIOS 301 and the loading 
programs and the trusted component 202. Therefore, for all practical purposes, 
on power down or re-boot, the trusted state 700 ceases to exist However, the 
ability to re-enter he trusted state 700 through a new operation of the boot 
process or re-boot process remains within the capabilities or the computing entity. 
The tmsted state is entered via a second boot process 1100 as herein before 
described. Once the trusted state is entered, a second session 1101 
commences. Within the second session 1101 the operating system, applications 
and facilities available from the computer platform are selected from the same set 
of such physical and logical resources as where available previously for the first 
session. However, usage of those facilities within the second session may vary 
according to a user's keystroke instmctions. Second session 1101 may 
effectively comprise a continuation of first session 1001. The user may call up 
the same application 1002 as previously and may effectively continue the work 
carried out during the first session in the second session 1101. However, 
because exiting the tmsted state involves the computer platform in complete 
amnesia of all events which occun'ed during that trusted state, after the state has 
been left, If the trusted state is reactivated and the new session is commenced, 
the application 1002 has no memory of its previous configuration. Therefore, 
stored output session data 1008 produced at the end of the first session 1001 
must be Input into the second session 1101 in order to reconfigure the 
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applicatlon, to save for example the settings of line spacing and format, and the 
output user data 1005 stored as stored output user data 1007 must be re-input 
Into the second session 1101 for further work to continue on that data. The 
stored session data 1008 and user data 1007 may be retrieved from a storage 
medium, decrypted and authenticated and then loaded into the trusted state, to 
configure the second session as a continuation of the first session. Preferably, 
Integrity measurement checks are perfomied by the trusted component on the 
user data and session data imported from the smartcard or storage medium, 
before that data is loaded. During the second session 1101, further user data 
1102 is input by the user, and the further data is processed together with the 
stored first output data 1007 according to the application 1002 configured 
according to the first stored output session data 1008 in process 1103. 
Processing of the data 1103 during the second session 1101 results in a new 
output user data 1 104. If the application or operating system used in the second 
session has changed in configuration during the second session, this results In a 
new session data 1105. As with the first session, in order to close the session 
without losing the settings of the application program, and operating system, and 
without losing the benefit of the wori< canied out during the second session, both 
the new session data 1 105 and the new output user data 1 104 need to be stored. 
These data are stored respectively as a stored new output user data 1 106 and a 
stored new session data 11 07. 

At the end of the second session, the session Is closed after having saved 
the wori< produced in the second session, and the trusted state is exited via a 
power down process or re-boot process 705, 707. All memory of the trusted 
state and second session other than that stored as the session data 1107 and 
stored output user data 1 106 is lost from the computer platfonn. 

It will be appreciated that the above example is a specific example of using 
a computer in successive first and second sessions on different days. In 
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between use of those sessions, the computing entity may be used in a piurallty of 
different states, for different purposes and different operations, with varying 
degrees of trust. In operating states which have a lower level of tmst, for 
example the second and third states (being 'untmsted' states) the computer entity 
5 will not lose memory of this data configuration between transitions from state to 
state. According to the above method of operation, the trusted state 700 may be 
activated any number of times, and any number of sessions carried out 
However, once the tmsted state is exited, the tmsted state has no memory of 
previous sessions. Any configuration of the trusted state must be by new input of 
10 data 1003, 1 102, or by input of previously stored session data or user data 1007, 
1008,1106,1107. 

In the above described specific implementations, specific methods, specific 
embodiments and modes of operation according to the present invention, a 
15 trusted state comprises a computer platfomi mnning a set of processes all of 
which are in a known state. Processes may be continuously monitored 
throughout a session operating in the tmsted state, by a trusted component 202. 

Referring to Fig. 12 herein, there is illustrated schematically a second mode 
20 of operation of a tmsted state, in which the tmsted component itself 202 can be 
reconfigured by a user. In the second mode of operation, the tmsted component 
stores a predetemnined set of data describing metrics which apply when the 
computer platfomn is in the tmsted state in which the component itself can be 
reconfigured. A tmsted state 1200 is entered as described previously herein 
25 through boot process 704 or re-boot process 705. In the tmsted state, a user 
enters a command to call up a tmsted component configuration menu in step 
1201 . The tmsted component configuration menu comprises a set of instmctions 
stored in memory and which is only accessible via a tmsted state. In order to 
make changes to the menu, various levels or security may be applied. For 
30 example, a user may be required to enter a secure password, for example a 
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password comprising numbers and letters or other characters in step 1202. The 
trusted component monitors the trusted state from which the trusted component 
can be reconfigured by comparing measured integrity metrics from the computer 
platform whilst in the trusted state, with the set of pre-stored integrity metrics 
which the trusted component stores in its own memory area. The trusted 
component will not allow a user to reconfigure the trusted component 202 unless 
the integrity metrics measured by the trusted component when the computer 
platfomi is in the trusted state from which the tmsted component can be 
reconfigured match the pre-stored values in the trusted component's own 
memory, thereby verifying that the computer platfomi is operating corectly in the 
tmsted state. The trusted component denies a user reconfiguration of the trusted 
component if the trusted component detects that the measured integrity metrics 
of the computer platform do not match those predetennined values which are 
stored in the trusted component's own intemal memory, and are those of the 
trusted state irom which the trusted component can be re-configured. 

Additionally, or optionally, the user may be required to Insert a smart card 
into smart card reader 103 In step 1203, following which the trusted component 
verifies the identity of the user by reading data Irom the smart card via smart card 
interface 305. Additionally, the user may be required to input physical 
confinnation of his or her presence by activation of confirmation key 104 
providing direct Input into tmsted component 202 as described with reference to 
Fig. 3 herein in step 1204. Data describing the tmsted state, for example, which 
operating system to use, and which applications to use, may be stored on the 
smart card and used to boot up the computer platfomi into the tmsted state. 

Once the security checks including the password, verification by smart card 
and/or activation of the confimiation key are accepted by the tmsted component, 
the file configuration menu is displayed on the graphical user interface under 
control of tmsted component 202 In step 1205. Reconfiguration of the tmsted 
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component can be made using the menu in step 1206 by the user. Depending 
upon the level of security applied, which is an implementation specific detail of 
the trusted component configuration menu, the user may need to enter further 
passwords and make further confimnation key activations when entering data Into 
the menu Itself. In step 1207, the user exits the trusted component 
reconfiguration menu having reconfigured the taisted component 

In the trusted component configuration menu, a user may reconfigure 
operation of the trusted component For example, a user may change the 
Integrity metrics used to monitor the computer platform. 

By storing predetermined digest data corresponding to a plurality of integrity 
metrics present in a state inside the trusted component's own memory, this may 
provide the tmsted component with data which it may compare with a digest data 
of a state into which the computer platfomn is booted, for the tmsted component 
to check that the computer platfomn has not been booted into an unauthorized 
state. 

The trusted component primarily monitors boot up of the computer platform. 
The tmsted component does not necessarily take control of the computer 
platform if the computer platfomi boots into an unauthorized state, although 
optionally, software may be provided within the tmsted component which enables 
the tmsted component to take control of the computer platfomi if the computer 
platfomi boots into an unauthorized, or an unrecognized state. 

When in the tmsted state, a user may load in new applications to use in that 
tmsted state, provided the user can authenticate those applications for use in the 
tmsted state. This may involve a user entering a signature data of the required 
application to the tmsted component, to allow the tmsted component to verify the 
application by means of its signature when loading the application into the tmsted 
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state. The trusted component checks that the signature of the application is the 
sanne as the signature which the user has loaded into the trusted component 
before actually loading the application. At the end of a session, the application is 
lost from the platfomi altogether. The session in the tmsted state exists only in 
temporary memory, for example random access memory, which is reset when the 
trusted state is exited. 

In the al3ove described implementations, a version of a computer entity in 
which a trusted component resides within a video path to a visual display unit 
have been described. However, the invention is not dependent upon a trusted 
component being present in a video path to a visual display unit, it will be 
understood by persons skilled in the art that the above best mode 
implementations are exemplary of a large class of implementations which can 
exist according to the invention. 

In the above described best mode embodiment, methods of operation have 
been described wherein a user is presented with a set of options for selecting a 
state from a plurality of states, and a user input is required in order to enter a 
particular desired state. For example a user input may be required to specify a 
particular type of operating system which is required to be used, corresponding to 
a state of the computer platform. In a further mode of operation of the specific 
embodiment, data for selecting a predetemnined operating state of the computer 
platform may be stored on a smart card, which is transportable from computer 
platform to computer platfomi, and which can be used to boot up a computer 
platfomi into a predetemnined required state. The smartcard responds to a set of 
state selection options presented by a BIOS, and selects one of a plurality of 
offered choices of state. The BIOS contains the state selections available, and a 
set of loading programs actually install the various operating systems which 
provide the states. In this mode of operation, rather than data describing a 
predetemnined state being stored within the first memory area of the trusted 
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component, and the BIOS system obtaining that data from the trusted component 
in order to boot the computer platform up into a required predeterniined state, the 
information can be accessed firom a smart card entered into the smart card 
reader. 

Using such a smart card pre-configured with data for selecting one or a 
plurality of predeterniined states, a user carrying the smart card may activate any 
such computing entity having a trusted component and computer platfonn as 
described herein into a predetermined state as specified by the user, with a 
laiowiedge that the computing entity will retain no record of the state after a user 
session has taken place. Similariy as described with reference to Figs. 10 and 1 1 
herein, any output user data or configuration data produced during a session may 
be verified by the smart card, which can be talten away by a user and used to 
boot up a further different computing entity into the same state, and continue a 
session on a different computing entity, verifying any infbmnation on user data or 
session data which Is to be retrieved, without either computing entity retaining a 
pemianent record of the predetenmined state, and without either computing entity 
retaining any of the processed user data or session configuration data of the 
predetemnined state. 
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Claims: 

1 . A computing entity comprising: 

5 a computer platfonn comprising a plurality of physical and logical resources 

including a first data processor and a first memory means; 

a monitoring component comprising a second data processor and a second 
memory means; 

10 

wherein, said computer platform is capable of operating in a plurality of 
different states, each said state utilising a corresponding respective set of 
individual ones of said physical and logical resources; 

15 wherein said monitoring component operates to determine which of said 

plurality of states said computer platform operates in. 

2. The computing entity as claimed in claim 1 . wherein a said memory 
means contains a set of instructions for configuration of said plurality of physical 

2 0 and logical resources of said computer platfonn into said pre-detemnined state. 

3. The computing entity as claimed in claim 1» in which exit of said 
computer platform from said pre-detemnined state is monitored by said monitoring 
component. 

25 

4. The computing entity as claimed in claim 1 , wherein said monitoring 
component includes a BIOS file. 



5. The computing entity as claimed in claim 1, wherein said computer 
3 0 platfonm comprises an intemal firmware component configured to compute a 
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digest data of a BIOS file data stored in a predetermined memory space 
occupied by a BIOS file of said computer platform. 

6. A method of activating a computing entity comprising a computer 
5 platfonn having a first data processing means and a first memory means and a 

monitoring component having a second data processing means and a second 
memory means, into an operational state of a plurality of pre-configured 
operational states into which said computer platform can be activated, said 
method comprising the steps of: 

10 

selecting a state of said plurality of pre-configured operational states into 
which to activate said computer platfonm; 

activating said computer platfomi into said selected state according to a set 
15 of stored instnjctions; 

wherein said monitoring component monitors activation into said selected 
state by recording data describing which of said plurality of pre-configured states 
said computer platform is activated into. 

20 

7. The method as claimed in claim 6, wherein said monitoring 
component continues to monitor said selected state after said computer platform 
has been activated into said state. 

25 8. The method as claimed in claim 6, wherein said monitoring 

component generates a state signal in response to a signal input directly to said 
monitoring component by a user of said computing entity, said state signal 
indicating which said state said computer platform has entered. 
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9* The method as claimed in claim 6, wherein said set of stored 
instructions are stored in a BIOS file resident within said monitoring component 

10. The method as claimed in claim 6, comprising the step of 
generating a menu for selection of a said pre-configured state from said plurality 
of pre-configured states. 

11. The method as claimed in claim 6, comprising the step of 
generating a user menu displayed on a user interface for selection of a said pre- 
configured state from said plurality of pre-configured states, and said step of 
generating a state signal comprises generating a state signal in response to a 
user input accepted through said user interface. 

12. The method as claimed in claim 7, in which said step of selecting a 
state of said plurality of pre-configured operational states comprises receiving a 
selection signal from a smartcard device, said selection signal instmcting a BIOS 
of said computer platform to activate the said computer platform into a said 
selected state. 

13. The method as claimed in claim 6, wherein said step of selecting a 
state of said plurality of pre-configured operational states comprises receiving a 
selection message from a network connection, said selection message instmcting 
a BIOS file of said computer platform to activate said computer platfomn into a 
said selected state. 

14. The method as claimed in claim 6, wherein said step of monitoring 
a said state comprises: 
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immediately before activating said computer platform, creating by means 
of a fimnware component a digest data of a first pre-allocated memory space 
occupied by a BIOS file of said computer platform; 

5 writing said digest data to a second pre-allocated memory space to which 

only said fimnware component has write access; and 

said monitoring component reading said digest data from said second pre- 
allocated memory space. 

10 

15. The method as claimed in claim 6, wherein said step of monitoring 
said state into which said computer platfomi is activated comprises: 

executing a firmware component to compute a digest data of a BIOS file of 
1 5 said computer platform; 

writing said digest data to a predetennined location in said second 
memory means of said monitoring component. 

20 16. The method as claimed in claim 6, wherein said step of activating 

said computer platfonm into said selected state comprises: 

at a memory location of said first memory means, said location occupied 
by a BIOS file of said computer platform, storing an address of said monitoring 
25 component which transfers control of said first processor to said monitoring 
component; 

storing in said monitoring component a set of native instructions which are 
accessible immediately after reset of said first processor, wherein said native 
30 instmctions instmct said first processor to calculate a digest of said BIOS file and 
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Store said digest data in said second memory means of said monitoring 
cx)mponent; and 

said monitoring component passing control of said activation process to 
5 said BIOS file, once said digest data is stored in said second memory means. 

17. The method as claimed in claim 6, wherein said step of monitoring 
said state into which said computer platfonn is activated comprises: 

10 after said step of activating said computer platform into said selected state, 

monitoring a plurality of logical and physical components to obtain a first set of 
metric data signals from those components, said metric data signals describing a 
status and condition of said components; 

15 comparing said first set of metric data signals detemnined from said 

plurality of physical and logical components of said computer platform, with a set 
of pre-recorded metric data stored in a memory area reserved for access only by 
said monitoring component; and 

20 comparing said first set of metric data signals obtained directly from said 

plurality of physical and logical components with said set of pre-stored metric 
data signals stored in said resen/ed memory area. 

18. A method of operating a computing entity comprising a computer 
25 platfomri having a first data processing means and a first memory means, and a 
monitoring component having a second data processing means and a second 
memory means, such that said computer platfonn enters one of a plurality of 
possible pre-determined operating states said method comprising the steps of: 



30 
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in response to an input from a user interface generating a said state signal, 
said state signal describing a selected state into which said computer piatform is 
to be activated into; 

5 activating said computer platform into a pre-determined state, in which a 

known set of physical and logical resources are available for use in said state and 
loiown processes can operate In said state; 

from said pre-determlned state, entering a configuration menu for 
10 reconfiguration of said monitoring component; and 

modifying a configuration of said monitoring component by entering data via 
a user interface In accordance with an instruction set comprising said 
configuration menu. 

15 

19. The method as claimed in claim 18, wherein said step of entering 
said monitoring component configuration menu comprises: 

entering a confimiation key signal directly into said monitoring component, 
20 said confirmation key signal generated in response to a physical activation of a 
confirmation key. 

20. The method as claimed in claim 18, wherein said step of entering 
said monitoring component configuration menu comprises entering a password to 

2 5 said tmsted component via a user interface. 

21. A method of operation of a computing entity comprising a 
monitoring component having a first data processing means and a first memory 
means, and a computer platfomi having a second data processing means and a 

3 0 second memory means, said method comprising the steps of: 
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entering a first state of said computer entity, wherein in said first state are 
available a plurality of pre-selected physical and logical resources; 

5 commencing a user session in said first state, in which said user session 

a plurality of data inputs are received by said computer platform, said second 
data processing means perfomning data processing on said received data; 

reconfiguring said plurality of physical and logical resources according to 
10 instructions received in said session; 

generating a session data describing a configuration of said physical and 
logical resources; 

15 generating a plurality of user data resulting from processes operating 

within said session; 

storing said user data; 

2 0 storing session data; 

exiting said session; and 

exiting said computer platfomn from said state, 

25 

22. The method as claimed in claim 21 , further comprising the step of: 



reconfiguring said monitoring component during said user session in said 
first state. 

30 
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